<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
    ul {
        padding: 0;
    }
    li {
        list-style: none;
        text-align: center;
    }
    .flex {
        padding: 0;
        height: 300px;
        display: flex;
        /*? wrap 使flex项目换行 如果将 flex-wrap 属性设置为 wrap ，且flex容器中的项目太多无法在一行上放置，则会将一些项目放到下一行*/
        flex-wrap: wrap;
        justify-content: space-evenly;
        align-items: center;
    }
    .flex li {
        background-color: skyblue;
        width: 33%;
        height: 100px;
        /*flex:1;*/
        line-height: 100px;
        margin-top: 10px;
        /*margin-left: 10px;*/
    }
    .float {

    }
    .float li {
        width: 32%;
        height: 100px;
        line-height: 100px;
        float: left;
        background-color: skyblue;
        margin-top: 10px;
        margin-left: 10px;

    }
    .grid {
        height: 300px;
        width: 100%;
        display: grid;
        /*? grid-template-columns 用于定义每一列的宽度； grid-template-rows 用于定义每一行的高度*/
        grid-template-columns: 32% 32% 32%;
        /*grid-template-rows: 30% 30% 30%;*/
        /*? grid-column-gap 用于设置网格列间距； grid-row-gap 用于设置网格行间距； grid-gap 是前两者的复合属性，第一个参数为行间距、第二个参数为列间距，也可以只用一个参数同时设置行和列。*/
        grid-gap: 1%;

    }
    .grid li {
        background-color: skyblue;
        height: 100px;
        line-height: 100px;
    }
    .table {
        display: table;
        width: 100%;
        height: 100%;
        border-spacing: 10px;
    }
    .table li {
        /*? 设置为表格行 所以这个的结构必须要加div*/
        display: table-row;
        line-height: 100px;
    }
    .table li div {
        display: table-cell;
        width: 30%;
        height: 30%;
        background-color: skyblue;
    }
</style>
<body>
flex
<div style="height: 400px">
<ul class="flex">
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
    <li>7</li>
    <li>8</li>
    <li>9</li>
</ul>
</div>
float
<div style="height: 400px">
<ul class="float">
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
    <li>7</li>
    <li>8</li>
    <li>9</li>
</ul>
</div>
grid
<div style="height: 400px">
    <ul class="grid">
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
        <li>8</li>
        <li>9</li>
    </ul>
</div>
table
<div style="height: 300px">
    <ul class="table">
        <li>
            <div>1</div>
            <div>2</div>
            <div>3</div>
        </li>
        <li>
            <div>4</div>
            <div>5</div>
            <div>6</div>
        </li>
        <li>
            <div>7</div>
            <div>8</div>
            <div>9</div>
        </li>
    </ul>
</div>
</body>
</html>
